## • Interrupción creada por un cambio de nivel

Los terminales RB4, RB5, RB6 y RB7 se pueden configurar para provocar una interrupción por cambio de nivel. Cumpliéndose que:

\_ De estos 4 terminales, sólo los configurados como *entradas* pueden provocar una interrupción.

\_ El bit INTCON.RBIF se pone a 1 siempre que la tensión presente en *cualquiera* de los 4 terminales (que estén configurados como entradas) describa un flanco de subida o bien un flanco de bajada (esta interrupción es sensible a ambos flancos). Esta interrupción no se puede hacer sensible únicamente a los flancos de subida o bien a los flancos de bajada. Para esto están las interrupciones INTO, INT1 e INT2.

*Importante*: para poder escribir un valor en el bit INTCON.RBIF <u>es necesario</u> leer previamente el contenido del registro PORTB. Esto no ocurre con ningún otro bit (*flag*) en un PIC18F452.

· Polling of PORTB is not recommended while using the interrupt on change feature.

```
Configuración de la interrupción RB (RB4, RB5, RB6 o RB7)
char x;
void interrupt() // rutina de servicio de la interrupción (MikroC)
 x = PORTB; // hay que leer el puerto B antes de borrar el flag
 INTCON.RBIF = 0; // se borra el flag
void main()
                                                     Nota: Sólo los terminales configurados
TRISB.Bx = 1; // x = 4, 5, 6, 7
                                                     como entradas pueden provocar una
x = PORTB;
                                                     interrupción.
INTCON.RBIF = 0; // se pone el flag a 0
INTCON.RBIE = 1; // se habilita la interrupción por cambio de nivel
INTCON.GIE = 1; // se habilitan las interrupciones en general
while(1)
```

|                                        | U1                                                                                                   |                                                                                              | _                                            |
|----------------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------|
| <u>13</u><br>_1                        | <del></del> -                                                                                        | 0/T1OSO/T1CKI<br>1/T1OSI/CCP2A                                                               | 15<br>16<br>17                               |
| 2<br>3<br>4<br>5<br>6<br>7             | RA0/AN0<br>RA1/AN1<br>RA2/AN2/VREF-<br>RA3/AN3/VREF+<br>RA4/T0CKI                                    | RC2/CCP1<br>RC3/SCK/SCL<br>RC4/SDI/SDA<br>RC5/SDO<br>RC6/TX/CK<br>RC7/RX/DT                  | 18<br>23<br>24<br>25<br>26                   |
| 33<br>34<br>35<br>36<br>37<br>38<br>39 | RA5/AN4/SS/LVDII<br>RA6/OSC2/CLKO<br>RB0/INT0<br>RB1/INT1<br>RB2/INT2<br>RB3/CCP2B<br>RB4<br>RB5/PGM | RD0/PSP0<br>RD1/PSP1<br>RD2/PSP2<br>RD3/PSP3<br>RD4/PSP4<br>RD5/PSP5<br>RD6/PSP6<br>RD7/PSP7 | 19<br>20<br>21<br>22<br>27<br>28<br>29<br>30 |
| 40                                     | RB6/PGC<br>RB7/PGD                                                                                   | RE0 <u>/RD</u> /AN5<br>RE1/ <u>WR</u> /AN6<br>RE2/CS/AN7                                     | 8<br>9<br>10                                 |
| PIC18F452                              |                                                                                                      |                                                                                              |                                              |